我编写了一个Java枚举,其中的值具有各种属性。这些属性可以通过以下任何一种方式存储:使用字段:enumEenum{V1(p1),V2(p2);privatefinalAattr;publicAattr(){returnattr;}privateEenum(Aattr){this.attr=attr;}}使用抽象方法:enumEenum{V1{publicAattr(){returnp1;}},V2{publicAattr(){returnp2;}}publicabstractAattr();}使用类级别map:enumEenum{V1,V2;publicAattr(){returna
据我了解,内部枚举在Java中始终是显式或隐式静态的。这意味着我无法从内部枚举类访问实例字段。publicclassInnerEnum{privateenumSomeInnerEnum{VALUE1(){@OverridepublicvoiddoSomething(){//ERROR:WON'TCOMPILE//Cannotmakestaticreference//tonon-staticfieldiSystem.out.println(i);}},VALUE2(){@OverridepublicvoiddoSomething(){//dosomethingelsewithi}};pu
我正在制作一种概率模拟器,它将运行一定的时间或一定的重复次数。我想优化一下,目前是多线程的,每个ProbabilityWorker扩展Thread,主程序会自动分配n个线程,其中n是但是有很多线程可用(例如:在我的Corei3-7100U上,这是4)。我正在分析它的性能,我意识到我用来获取相对于结束时间的当前时间的方法会导致大量开销。对于它可以“运行一定时间”的模式,我将newDate对象作为循环条件的一部分,然后我将其更改为更快的System.currentTimeMillis()试图节省时间,但我注意到即使这样也会产生开销。我的run函数如下所示:publicvoidrun(){i
我正在使用这样的枚举单例模式:publicenumLicenseLoaderimplementsClientLicense{INSTANCE;/***@returnaninstanceofClientLicense*/publicstaticClientLicensegetInstance(){return(ClientLicense)INSTANCE;}...restofcode}现在我想返回接口(interface)并隐藏我们实际使用枚举的事实。我希望客户端使用getInstance()而不是LicenseLoader.INSTANCE,因为有一天我可能会在必要时决定使用不同的模式
我在hibernate中使用native查询来为包含枚举属性的bean起别名时遇到问题。调用query.list()时出现InvocationTargetException。我的例子如下:@Entity(name="table1")publicclassClass1{@Column(name="col1")@NotNullprivateIntegerprop1;@Column(name="col2")@NotNullprivateStringprop2;@Column(name="col3",length=6)@Enumerated(value=EnumType.STRING)priv
我有一个用于几个域类的描述符类。描述符类有一个字段“type”,它是一个枚举,表示域类的类型。在某些查询中,我想返回一个或多个描述符并将类型作为构造函数参数传递。所以我的想法是将它作为查询参数传递:Stringjpql="SELECTNEWmodel.ModelDescriptor"+"(t.id,t.name,t.description,:modelType)...";TypedQueryquery=em.createQuery(jpql,ModelDescriptor.class);query.setParameter("modelType",ModelType.forClass(
假设我有一个Enum定义如下:publicenumSample{//supposeAClass.getValue()returnsanintA(AClass.getValue()),B(AClass.getValue()),C(AClass.getValue());privateint_value;privateSample(int_val){this._value=_val;}publicintgetVal(){return_value;}我可以使用Sample.A或Sample.A.getAVal()毫无问题地提取值。现在假设AClass.getValue()可以接受一个参数来返回
我正在为用户偏好创建一个商店,用户可以为固定数量的偏好设置值。首选项(设置)的名称存储为枚举:publicenumUserSettingName{FOO,BAR,ETC}我希望能够做的是存储一个带有名称的值类型,以便服务将使用正确的Java类型存储用户的值。例如,FOO可能是Long,而BAR可能是String。到目前为止,我们将所有值存储为String,然后手动将这些值转换为适当的Java类型。这导致到处都是try/catchblock,而在服务中只有一个try/catch更有意义。我知道枚举不能有通用类型,所以我一直在玩:publicenumUserSettingName{FOO(
我有如下所示的简单枚举类。我想知道内存是如何分配给每个常量的(是否为每个常量创建了成员类对象)以及它的范围是什么。publicenumMember{HAPPY("HAPPY"),RAhul("RAhul"),ANSAL("ANSAL");privateStringargument;Member(Stringarguments){System.out.println("EnumConstructorwork");this.argument=arguments;}publicStringgetValue(){returnargument;}} 最佳答案
正如指出的那样herelambda提供了一种非常优雅的方式来指定单个枚举值的行为。在Java8之前,我通常会将其实现为:enumOperator{TIMES{publicintoperate(intn1,intn2){returnn1*n2;}},PLUS{publicintoperate(intn1,intn2){returnn1+n2;}};publicintoperate(intn1,intn2){thrownewAssertionError();}}现在我倾向于使用:enumOperator{TIMES((n1,n2)->n1*n2),PLUS((n1,n2)->n1+n2);